var prefix = ctx + "/system/upmsDictData";
var dictDataType = "sys_dict_status"
var dictDataList = {}



$(function() {
    getDictLabel(dictDataType);
    load();
});

function load() {
    $('#exampleTable')
        .bootstrapTable(
            {
                method : 'get', // 服务器数据的请求方式 get or post
                url : prefix + "/list", // 服务器数据的加载地址
                showRefresh : true,
                showToggle : true,
                showColumns : true, // 是否显示内容下拉框（选择显示的列）
                iconSize : 'outline',
                toolbar : '#exampleToolbar',
                striped : true, // 设置为true会有隔行变色效果
                dataType : "json", // 服务器返回的数据类型
                pagination : true, // 设置为true会在底部显示分页条
                // queryParamsType : "limit",
                // //设置为limit则会发送符合RESTFull格式的参数
                singleSelect : false, // 设置为true将禁止多选
                // contentType : "application/x-www-form-urlencoded",
                // //发送到服务器的数据编码类型
                pageSize : 10, // 如果设置了分页，每页数据条数
                pageNumber : 1, // 如果设置了分布，首页页码
                //search : true, // 是否显示搜索框
                sidePagination : "server", // 设置在哪里进行分页，可选值为"client" 或者 "server"
                queryParams : function(params) {
                    return {
                        //说明：传入后台的参数包括offset开始索引，limit步长，sort排序列，order：desc或者,以及所有列的键值对
                        limit: params.limit,
                        offset:params.offset,
                        dictType:$('#dictType').val()
                       // username:$('#searchName').val()
                    };
                },
                // //请求服务器数据时，你可以通过重写参数的方式添加一些额外的参数，例如 toolbar 中的参数 如果
                // queryParamsType = 'limit' ,返回参数必须包含
                // limit, offset, search, sort, order 否则, 需要包含:
                // pageSize, pageNumber, searchText, sortName,
                // sortOrder.
                // 返回false将会终止请求
                columns : [
                        {
                            checkbox : true
                        },
                                                        {
                            field : 'dictCode',
                            title : '字典编码',
                            align : 'center'
                        },
                                                        {
                            field : 'dictType',
                            title : '字典类型',
                            align : 'center'
                        },
                                                        {
                            field : 'dictLabel',
                            title : '字典标签',
                            align : 'center',
                            formatter : function(value, row, index) {
                                if(row.listClass != '') {
                                    return "<span class='label label-"+row.listClass+"'>"+value+"</span>";
                                }else {
                                    return value;
                                }
                            }
                        },
                                                        {
                            field : 'dictValue',
                            title : '字典键值',
                            align : 'center'
                        },
                                                        {
                            field : 'remark',
                            title : '备注',
                            align : 'center'
                        },
                                                        {
                            field : 'cssClass',
                            title : '样式属性',
                            align : 'center'
                        },
                                                        {
                            field : 'isDefault',
                            title : '是否默认',
                            align : 'center',
                            formatter : function(value, row, index) {
                                if(value == "Y") {
                                    return "<span class='label label-success'>是</span>";
                                } else if(value == "N") {
                                    return "<span class='label label-danger'>否</span>";
                                } else {
                                    return "<span class='label label-warning'>未知</span>";
                                }
                            }
                        },
                                                        {
                            field : 'status',
                            title : '状态',
                            align : 'center',
                            formatter : function(value, row, index) {
                                return selectDictLabel(dictDataList, value);
                            }
                        },
                                                        {
                            field : 'dictSort',
                            title : '字典排序',
                            align : 'center'
                        },
                                                        {
                            title : '操作',
                            field : 'id',
                            align : 'center',
                            formatter : function(value, row, index) {
                                var e = '<a class="btn btn-primary btn-sm '+s_edit_h+'" href="#" mce_href="#" title="编辑" onclick="edit(\''
                                        + row.dictCode
                                        + '\')"><i class="fa fa-edit"></i></a> ';
                                var d = '<a class="btn btn-warning btn-sm '+s_remove_h+'" href="#" title="删除"  mce_href="#" onclick="remove(\''
                                        + row.dictCode
                                        + '\')"><i class="fa fa-remove"></i></a> ';
                                var f = '<a class="btn btn-success btn-sm" href="#" title="备用"  mce_href="#" onclick="resetPwd(\''
                                        + row.dictCode
                                        + '\')"><i class="fa fa-key"></i></a> ';
                                return e + d ;
                            }
                        } ]
            });
}
function reLoad() {
    $('#exampleTable').bootstrapTable('refresh');
}
function add() {
    layer.open({
        type : 2,
        title : '增加',
        maxmin : true,
        shadeClose : false, // 点击遮罩关闭层
        area : [ '800px', '520px' ],
        content : prefix + '/add' // iframe的url
    });
}
function edit(id) {
    layer.open({
        type : 2,
        title : '编辑',
        maxmin : true,
        shadeClose : false, // 点击遮罩关闭层
        area : [ '800px', '520px' ],
        content : prefix + '/edit/' + id // iframe的url
    });
}
function remove(id) {
    layer.confirm('确定要删除选中的记录？', {
        btn : [ '确定', '取消' ]
    }, function() {
        $.ajax({
            url : prefix+"/remove",
            type : "post",
            data : {
                'dictCode' : id
            },
            success : function(r) {
                if (r.code==0) {
                    layer.msg(r.msg);
                    reLoad();
                }else{
                    layer.msg(r.msg);
                }
            }
        });
    })
}

function resetPwd(id) {
}
function batchRemove() {
    var rows = $('#exampleTable').bootstrapTable('getSelections'); // 返回所有选择的行，当没有选择的记录时，返回一个空数组
    if (rows.length == 0) {
        layer.msg("请选择要删除的数据");
        return;
    }
    layer.confirm("确认要删除选中的'" + rows.length + "'条数据吗?", {
        btn : [ '确定', '取消' ]
    // 按钮
    }, function() {
        var ids = new Array();
        // 遍历所有选择的行数据，取每条数据对应的ID
        $.each(rows, function(i, row) {
            ids[i] = row['dictCode'];
        });
        $.ajax({
            type : 'POST',
            data : {
                "ids" : ids
            },
            url : prefix + '/batchRemove',
            success : function(r) {
                if (r.code == 0) {
                    layer.msg(r.msg);
                    reLoad();
                } else {
                    layer.msg(r.msg);
                }
            }
        });
    }, function() {

    });
}

//退回
function goBack() {
    window.location = ctx + "/system/upmsDictType";
}


//获取标签样式
function getDictLabel(dictType) {
    $.ajax({
        type : 'GET',
        data : {
            "dictType" : dictType
        },
        url : ctx + '/system/upmsDictData/useList',
        success : function(r) {
            dictDataList = r.rows;
        }
    });
}

//选择标签样式
function selectDictLabel(list, value) {
    if(list == null) {
        getDictLabel(dictDataType);
    }
    for(let index in list) {
        if(list[index].dictValue == value) {
            return "<span class='label label-"+ row.listClass +"'>"+row.dictLabel+"</span>";
        }
    }
    return value;
}